<!-- pages/login/components/mobile.vue -->
<script setup>
	import { ref } from 'vue'
	import { verifyCodeApi, loginByMobileApi } from '@/services/user'
	import { useUserStore } from '@/stores/user'

	// 用户相关的数据
	const userStore = useUserStore()
	// 是否同意协议
	const isAgree = ref(false)
	// 是否显示倒计时组件
	const showCountdown = ref(false)
	// 按钮文件
	const buttonText = ref('获取验证码')
	// 获取组件实例
	const formRef = ref()
	// 表单数据
	const formData = ref({
		mobile: '13210090581',
		code: '',
	})

	// 验证表单数据的规则
	const formRules = {
		mobile: {
			rules: [
				{ required: true, errorMessage: '请填写手机号码' },
				{ pattern: '^1\\d{10}$', errorMessage: '手机号码格式不正确' },
			],
		},
		code: {
			rules: [
				{ required: true, errorMessage: '请输入验证码' },
				{ pattern: '^\\d{6}$', errorMessage: '验证码格式不正确' },
			],
		},
	}

	// 发送短信验证码
	async function onTextButtonClick() {
		// 验证表单数据（手机号）
		await formRef.value.validateField(['mobile'])

		// 调用接口，发送短信
		const { code, message } = await verifyCodeApi({
			mobile: formData.value.mobile,
			type: 'register',
		})
		// 检测接口是否调用成功
		if (code !== 10000) return uni.utils.toast(message)

		uni.utils.toast('验证码已发送，请查收!')

		// 显示倒计时组件
		showCountdown.value = true
	}

	// 提交表单数据
	async function onFormSubmit() {
		// 判断是否勾选协议
		if (!isAgree.value) return uni.utils.toast('请确认勾选协议')

		// 调用 uniForms 组件验证数据的方法
		try {
			// 验证通过后会返回表单的数据
			const formData = await formRef.value.validate()
			// 提交表单数据
			const { code, data, message } = await loginByMobileApi(formData)
			// 检测接口是否调用成功
			if (code !== 10000) return uni.utils.toast(message)

			// 持久化存储 token
			userStore.token = data.token
			// 临时跳转到首页
			// uni.switchTab({
			// 	url: '/pages/index/index',
			// })
			// 跳转到登录前的页面
			uni[userStore.openType]({
				url: userStore.redirectURL,
			})
		} catch (error) {
			console.log(error)
		}
	}

	// 监听倒计时组件是否结束
	function onCountdownTimeup() {
		// 变更提示文字
		buttonText.value = '重新获取验证码'
		// 隐藏倒计时组件
		showCountdown.value = false
	}

	// 是否同意协议
	function onAgreeClick() {
		isAgree.value = !isAgree.value
	}
</script>

<template>
	<uni-forms
		class="login-form"
		:model="formData"
		:rules="formRules"
		ref="formRef"
	>
		<uni-forms-item name="mobile">
			<uni-easyinput
				v-model="formData.mobile"
				:input-border="false"
				:clearable="false"
				placeholder="请输入手机号"
				placeholder-style="color: #C3C3C5"
			/>
		</uni-forms-item>
		<uni-forms-item name="code">
			<uni-easyinput
				v-model="formData.code"
				:input-border="false"
				:clearable="false"
				placeholder="请输入验证码"
				placeholder-style="color: #C3C3C5"
			/>
			<view v-if="showCountdown" class="text-button">
				<custom-countdown
					:second="5"
					:show-day="false"
					:show-hour="false"
					:show-miniute="false"
					@timeup="onCountdownTimeup"
					color="#16C2A3"
				/>秒后重新获取
			</view>
			<text v-else @click="onTextButtonClick" class="text-button">
				{{ buttonText }}
			</text>
		</uni-forms-item>

		<view class="agreement">
			<radio @click="onAgreeClick" :checked="isAgree" color="#16C2A3" />
			我已同意
			<text class="link">用户协议</text>
			及
			<text class="link">隐私协议</text>
		</view>

		<button class="uni-button" @click="onFormSubmit">登 录</button>
	</uni-forms>
</template>

<script>
	export default {
		options: {
			styleIsolation: 'shared',
		},
	}
</script>

<style lang="scss">
	@import './styles.scss';
</style>
